home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in C++ V2 / C20 / IndexingVsAt.cpp < prev    next >
Encoding:
C/C++ Source or Header  |  2000-05-25  |  1.2 KB  |  45 lines

  1. //: C20:IndexingVsAt.cpp
  2. // From Thinking in C++, 2nd Edition
  3. // Available at http://www.BruceEckel.com
  4. // (c) Bruce Eckel 1999
  5. // Copyright notice in Copyright.txt
  6. // Comparing "at()" to operator[]
  7. #include "../require.h"
  8. #include <vector>
  9. #include <deque>
  10. #include <iostream>
  11. #include <ctime>
  12. using namespace std;
  13.  
  14. int main(int argc, char* argv[]) {
  15.   requireMinArgs(argc, 1);
  16.   long count = 1000;
  17.   int sz = 1000;
  18.   if(argc >= 2) count = atoi(argv[1]);
  19.   if(argc >= 3) sz = atoi(argv[2]);
  20.   vector<int> vi(sz);
  21.   clock_t ticks = clock();
  22.   for(int i1 = 0; i1 < count; i1++)
  23.     for(int j = 0; j < sz; j++)
  24.       vi[j];
  25.   cout << "vector[]" << clock() - ticks << endl;
  26.   ticks = clock();
  27.   for(int i2 = 0; i2 < count; i2++)
  28.     for(int j = 0; j < sz; j++)
  29.       vi.at(j);
  30.   cout << "vector::at()" << clock()-ticks <<endl;
  31.   deque<int> di(sz);
  32.   ticks = clock();
  33.   for(int i3 = 0; i3 < count; i3++)
  34.     for(int j = 0; j < sz; j++)
  35.       di[j];
  36.   cout << "deque[]" << clock() - ticks << endl;
  37.   ticks = clock();
  38.   for(int i4 = 0; i4 < count; i4++)
  39.     for(int j = 0; j < sz; j++)
  40.       di.at(j);
  41.   cout << "deque::at()" << clock()-ticks <<endl;
  42.   // Demonstrate at() when you go out of bounds:
  43.   di.at(vi.size() + 1);
  44. } ///:~
  45.